<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <!-- 
        总结
        Vue监视数据的原理:
            1.vue会监视data中所有层次的数据
            2.如何检测对象中的数据?
                通过setter实现监视，而且要在new Vue 的时候传入检测的数据
                    1.对象中后追加的属性，Vue默认不做响应式的处理
                    2.如果需要给后添加的属性做响应式，需要使用如下API:
                        Vue.set(target,propertyName/index,value) 或
                        vm.$set(target,propertyName/index,value)

            3.如何检测数组中的数据？
                通过包裹数组更新元素的方法实现，本质就是做了两件事：
                    ①调用原生对应的方法进行数组的更新
                    ②重新解析模板，进而更新页面
            
            4.Vue修改数组中的某一元素一定要使用如下方法：
                1.使用这些API: push() pop() shift() unshift() sort() splice() reverse()
                2.Vue.set() 或者 vm.$set()

        特别注意:Vue.set() 和 vm.$set() 不能给 vm 或 vm的根数据对象 添加属性!!!
     -->

    <div id="root">
        <h1>学生信息</h1>
        <button @click="student.age++">年龄+1</button><br>
        <button @click="addGender">添加性别属性，默认男</button><br>
        <button @click=" student.gender = '未知' ">修改性别</button><br>
        <button @click="addFriendAtFirst">在列表首位添加一位朋友</button><br>
        <button @click="setFirstFriend">修改第一个朋友名字为张三</button><br>
        <button @click="addHobby">添加一个爱好</button><br>
        <button @click="updateHobby">修改第一个爱好为:开车</button><br>
        <button @click="filterHobby">过滤掉爱好中的抽烟</button><br>
        <h2>姓名：{{student.name}}</h2>
        <h2>年龄：{{student.age}}</h2>
        <h2 v-if="student.gender">性别：{{student.gender}}</h2>
        <h2>爱好</h2>
        <ul>
            <li v-for="(h,index) in student.hobby" :key="index">
                {{h}}
            </li>
        </ul>
        <h2>朋友</h2>
        <ul>
            <li v-for="(friend,index) in student.friends" :key="index">
                {{friend.name}}--{{friend.age}}
            </li>
        </ul>


    </div>

    <script>
        Vue.config.productionTip = false;
        new Vue({
            el: "#root",
            data() {
                return {
                    student: {
                        name: "tom",
                        age: 18,
                        hobby: ["抽烟", "喝酒", "烫头"],
                        friends: [
                            {
                                name: "jerry",
                                age: 19
                            },
                            {
                                name: "tony",
                                age: 20
                            }
                        ],
                    }
                }
            },
            methods: {
                addGender() {
                    // Vue.set(this.student, "gender", "男");
                    this.$set(this.student, "gender", "男");
                },
                addFriendAtFirst() {
                    const f = {
                        name: "jack",
                        age: 20
                    };
                    this.student.friends.unshift(f);
                },
                setFirstFriend() {
                    // 验证后添加的数组对象属性是不是响应式的
                    this.student.friends[0].name = "张三";
                },
                addHobby() {
                    this.student.hobby.push("玩游戏");
                },
                updateHobby() {
                    this.student.hobby.splice(0, 1, "开车");
                },
                filterHobby() {

                    this.student.hobby = this.student.hobby.filter((h) => {
                        // 注意filter不影响原数组的改变
                        return h !== "抽烟";
                    })
                }
            },
        })
    </script>

</body>

</html>